PHP 的redis
扩展是阻塞式 IO ,使用订阅/发布模式时,会导致整个进程进入阻塞。因此必须使用Swoole\Redis
异步客户端来实现。
实例代码
$server = new swoole_websocket_server("0.0.0.0", 9501);
$server->on('workerStart', function ($server, $workerId) {
$client = new swoole_redis;
$client->on('message', function (swoole_redis $client, $result) use ($server) {
if ($result[0] == 'message') {
foreach($server->connections as $fd) {
$server->push($fd, $result[1]);
}
}
});
$client->connect('127.0.0.1', 6379, function (swoole_redis $client, $result) {
$client->subscribe('msg_0');
});
});
$server->on('open', function ($server, $request) {
});
$server->on('message', function (swoole_websocket_server $server, $frame) {
$server->push($frame->fd, "hello");
});
$server->on('close', function ($serv, $fd) {
});
$server->start();
实现过程
在进程启动(
onWorkerStart
)时创建了Swoole\Redis
客户端,连接到Redis
服务器连接成功后,订阅
msg_0
主题的消息当有新的
message
时,Swoole\Redis
会触发onMessage
事件回调在这个回调函数中使用
$server->connections
遍历服务器所有的连接,发送消息
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。最后使用 process 解决的, 用一个单独的 process 来跑 redis sub
?,希望swoole越来越好
这个类哪里来呀swoole_redis
有 2 点疑问:
workStart
回调中初始化, 这样的话, 这里是不是每个 worker 进程都会起一个 swoole_redis 来监听, 导致消息被重复广播?帮每个worker 订阅 编个号,发布订阅的时候,发给2个订阅不就解决重复的问题了
韩总,demo中的实例代码,会订阅多次。如果只想订阅一次,应该如何写更好呢?
麻烦问下,之前这代码跑起来没问题,现在重装后,启动时候提示不能使用 new swoole_redis; 只让使用协程的new SwooleCoroutineRedis();
是啥情况
请问一下我在 open 事件的时候能获取到userinfo, 然后需要根据其中的userid 去redis 查找 userid_messages 这样名称的队列,在哪里实现监听redis 队列的数据变动?workerstart 的时候没有userid